package co.yixiang.modules.supplier.service;

import co.yixiang.modules.supplier.domain.SupplierGoodsSkuLog;
import co.yixiang.modules.supplier.service.dto.SupplierGoodsSkuDto;
import co.yixiang.modules.supplier.service.dto.SupplierGoodsSkuLogDto;
import co.yixiang.modules.supplier.service.dto.SupplierGoodsSkuLogQueryCriteria;
import org.springframework.data.domain.Pageable;
import java.util.Map;
import java.util.List;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;

/**
* @author Walert
* @date 2021-03-27
*/
public interface SupplierGoodsSkuLogService {

    /**
    * 查询数据分页
    * @param criteria 条件
    * @param pageable 分页参数
    * @return Map<String,Object>
    */
    Map<String,Object> queryAll(SupplierGoodsSkuLogQueryCriteria criteria, Pageable pageable);

    /**
    * 查询所有数据不分页
    * @param criteria 条件参数
    * @return List<SupplierGoodsSkuLogDto>
    */
    List<SupplierGoodsSkuLogDto> queryAll(SupplierGoodsSkuLogQueryCriteria criteria);

    /**
     * 根据ID查询
     * @param id ID
     * @return SupplierGoodsSkuLogDto
     */
    SupplierGoodsSkuLogDto findById(Long id);

    /**
    * 创建
    * @param resources /
    * @return SupplierGoodsSkuLogDto
    */
    SupplierGoodsSkuLogDto create(SupplierGoodsSkuLog resources);

    /**
    * 编辑
    * @param resources /
    */
    void update(SupplierGoodsSkuLog resources);

    /**
    * 多选删除
    * @param ids /
    */
    void deleteAll(Long[] ids);

    /**
    * 导出数据
    * @param all 待导出的数据
    * @param response /
    * @throws IOException /
    */
    void download(List<SupplierGoodsSkuLogDto> all, HttpServletResponse response) throws IOException;

    void make30dayPrice(Long skuId, Integer capacity);

    void saveSkuLog(SupplierGoodsSkuDto goodsSku, long changeTime);
}
